﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "/common/link.ftl">
</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm">
                    <input type="hidden" name="id" value="${employee.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="username"
                                    <#--如果有对象就代表是修改 用户名改为只读-->
                                    <#if employee??>
                                        disabled
                                    </#if>
                                   placeholder="请输入用户名" value="${employee.username}">
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="name" placeholder="请输入真实姓名"
                                   value="${employee.name}">
                        </div>
                    </div>
                    <#--新增时需要显示,编辑的时候不需要显示-->
                    <#--employee是否存在-->
                    <#if !employee??>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"
                                       placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword"
                                       placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="email" placeholder="请输入邮箱"
                                   value="${employee.email}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="age" placeholder="请输入年龄"
                                   value="${employee.age}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <option value="">全部</option>
                                Z
                                <#list departments as d>
                                    <option value="${d.id}" ${(d.id==employee.dept.id)?string('selected','')}>${d.name}</option>
                                </#list>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6" style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                        </div>
                        <script>
                            <#if employee?? && employee.admin >
                            $('#admin').prop('checked', true);
                            </#if>
                        </script>
                    </div>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list role as r1>
                                        <option value="${r1.id}">${r1.name}</option>
                                    </#list>
                                </select>
                            </div>
                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list roleSelected as r>
                                        <option value="${r.id}">${r.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>
                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="button" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>
                </form>
            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">
</div>
<script>
    //点击保持按钮提交表单
    $('.btn-submit').click(function () {
        //让右边的下拉框全选中状态
        $('.selfRoles >option').prop('selected', true)
        //提交表单
        $('#editForm').submit();//添加了Bootstrap-validator插件这个提交就变成插件触发
    });
    //消除两边角色框相同
    var ids = [];
    $('.selfRoles >option').each(function (index, element) {
        ids.push($(element).val())
    });
    $('.allRoles >option').each(function (index, element) {
        var id = $(element).val();
        //如果这个数组含有这个值就删除
        if ($.inArray(id, ids) > -1) {
            $(element).remove();
        }
    });


    //如果是超级管理员 隐藏角色框
    //勾选使就隐藏
    var role;
    $('#adminDiv').click(function () {
        if ($('#admin').prop('checked')) {
            role = $('#roleDiv').remove();
        } else {
            $('#adminDiv').after(role);
        }
    });
    //加载页面的时候判断是不是管理员,如果使就把role隐藏
    if ($('#admin').prop('checked')) {
        role = $('#roleDiv').remove();
    }

    //实现角色左右移
    function moveAll(src, target) {
        //$('.selRole').prop('selected',true)
        //$('.selRole').prop('selected',true)
        var sel = $('.' + src + '> option');
        $('.' + target).append(sel);
    }

    function moveSelected(src, target) {
        //$('.selRole >option:selected')
        var options = $('.' + src + '> option:selected');
        $('.' + target).append(options)
    }

    $("#editForm").bootstrapValidator({
        feedbackIcons: { //图标
            valid: 'glyphicon glyphicon-ok',
            invalid: 'glyphicon glyphicon-remove',
            validating: 'glyphicon glyphicon-refresh'
        },
        fields: { //配置要验证的字段
            username: {
                validators: { //验证的规则
                    notEmpty: { //不能为空
                        message: "用户名都不填想我给你填?" //错误时的提示信息
                    },
                    stringLength: { //字符串的长度范围
                        min: 1,
                        max: 10
                    },
                    remote: { //远程验证
                        type: 'POST', //请求方式
                        url: '/employee/checkName', //请求地址
                        message: '用户名已经存在', //验证不通过时的提示信息
                        delay: 1000, //输入内容2秒后发请求
                    }
                }
            },
            name: {
                validators: { //验证的规则
                    notEmpty: { //不能为空
                        message: "狗蛋你没名字吗?" //错误时的提示信息
                    },
                    stringLength: { //字符串的长度范围
                        min: 1,
                        max: 5
                    }
                }
            },
            password: {
                validators: {//验证规则
                    notEmpty: {
                        message: '密码都不设,玩蛇呢'
                    },
                    different: {//不能与下面的元素用相同的值
                        field: 'username', //值不能相同的值
                        message: '你家密码和用户名一样吗?'
                    }
                }
            },
            repassword: {
                validators: {
                    notEmpty: {//不能为空,否则提示下面
                        message: '再打一次密码会不会!!'
                    },
                    identical: {//判断下面关联的值是不是一样
                        field: 'password', // 关联的值
                        message: '重复密码都不会玩个蛇皮'
                    }
                }
            },
            email: {
                validators: {
                    notEmpty: {//不能为空,否则提示下面
                        message: '你这是没邮箱?!!不会注册一个啊'
                    },
                    emailAddress: {//邮箱格式 出错
                        message: '邮箱格式会不会写!!'
                    }


                }
            },
            age: {
                validators: {
                    notEmpty: {//不能为空,否则提示下面
                        message: '王母娘娘你贵庚?'
                    },
                    between: { //数字的范围
                        min: 18, max: 60 // dept.id
                    }
                }
            },
            'dept.id': {
                validators: {
                    notEmpty: {//不能为空,否则提示下面
                        message: '选个部门可好?'
                    },
                }
            }
        }
    }).on('success.form.bv', function () { //表单所有数据验证通过后执行里面的代码
        //提交异步表单
        $.post('/employee/saveOrUpdate',$('#editForm').serialize(),function (data) {
            if(data.success){
                Swal.fire({
                    title: '保存完成',
                    icon: 'success'
                }).then(() => {
                    window.location.href = "/employee/list";
                })
            }else {
                Swal.fire(
                    '保存失败',
                    data.msg,
                    'error'
                )
            }
        })
    });
</script>
</body>
</html>
